package cn.iocoder.yudao.module.shop.service.itemtimes;

import java.util.*;
import javax.validation.*;
import cn.iocoder.yudao.module.shop.controller.admin.itemtimes.vo.*;
import cn.iocoder.yudao.module.shop.dal.dataobject.itemtimes.ShopItemTimesDO;
import cn.iocoder.yudao.framework.common.pojo.PageResult;

/**
 * 店内项目次数 Service 接口
 *
 * @author 曹建伟
 */
public interface ShopItemTimesService {

    /**
     * 创建店内项目次数
     *
     * @param createReqVO 创建信息
     * @return 编号
     */
    Long createItemTimes(@Valid ShopItemTimesCreateReqVO createReqVO);

    /**
     * 更新店内项目次数
     *
     * @param updateReqVO 更新信息
     */
    void updateItemTimes(@Valid ShopItemTimesUpdateReqVO updateReqVO);

    /**
     * 删除店内项目次数
     *
     * @param id 编号
     */
    void deleteItemTimes(Long id);

    /**
     * 获得店内项目次数
     *
     * @param id 编号
     * @return 店内项目次数
     */
    ShopItemTimesDO getItemTimes(Long id);

    ShopItemTimesDO getItemTimes(Long memberId, Long itemId);

    /**
     * 获得店内项目次数列表
     *
     * @param ids 编号
     * @return 店内项目次数列表
     */
    List<ShopItemTimesDO> getItemTimesList(Collection<Long> ids);

    List<ShopItemTimesDO> getAll(Long memberId);

    /**
     * 获得店内项目次数分页
     *
     * @param pageReqVO 分页查询
     * @return 店内项目次数分页
     */
    PageResult<ShopItemTimesDO> getItemTimesPage(ShopItemTimesPageReqVO pageReqVO);

    /**
     * 获得店内项目次数列表, 用于 Excel 导出
     *
     * @param exportReqVO 查询条件
     * @return 店内项目次数列表
     */
    List<ShopItemTimesDO> getItemTimesList(ShopItemTimesExportReqVO exportReqVO);

    /**
     * 添加项目次数
     */
    void addTimes(Long memberId, Long itemId, Integer times, String reason, Integer price, Long tenantId);

    /**
     * 减少项目次数
     */
    void subTimes(Long memberId, Long itemId, Integer times, String reason, Long tenantId);

    void rollbackTimes(Long memberId, Long itemId, Integer times, String reason, Long tenantId);

}
